import js from '@eslint/js'
import globals from 'globals'
import reactHooks from 'eslint-plugin-react-hooks'
import reactRefresh from 'eslint-plugin-react-refresh'
import tseslint from 'typescript-eslint'

export default tseslint.config(
  { ignores: ['dist'] },
  {
    extends: [js.configs.recommended, ...tseslint.configs.recommended],
    files: ['**/*.{ts,tsx}'],
    languageOptions: {
      ecmaVersion: 2020,
      globals: globals.browser
    },
    plugins: {
      'react-hooks': reactHooks,
      'react-refresh': reactRefresh
    },
    rules: {
      ...reactHooks.configs.recommended.rules,
      'react-refresh/only-export-components': ['warn', { allowConstantExport: true }],
      '@typescript-eslint/no-explicit-any': 'off', // 可用 any
      '@typescript-eslint/no-unused-vars': 1,
      '@typescript-eslint/no-namespace': 'off', // 允许命名空间
      '@typescript-eslint/no-unused-vars': 1,
      'react-hooks/exhaustive-deps': 'off', // 允许 useEffect 空数组
      '@typescript-eslint/no-unused-vars': '1' // 解构变量未使用
    }
  }
)
